package com.zhu.gataway.config;

import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;

import org.springframework.web.cors.CorsConfiguration;

import org.springframework.web.cors.reactive.CorsWebFilter;
import org.springframework.web.cors.reactive.UrlBasedCorsConfigurationSource;
import org.springframework.web.util.pattern.PathPatternParser;


@Configuration
public class CrosConfig {
    /**
         * 跨域配置
         * @return
         */
        private CorsConfiguration buildConfig() {
            CorsConfiguration corsConfiguration = new CorsConfiguration();
            // 预检请求的缓存时间（秒），即在这个时间段里，对于相同的跨域请求不会再预检了
            corsConfiguration.setMaxAge(18000L);
            // 允许cookies跨域
            corsConfiguration.setAllowCredentials(true);
            // 允许向该服务器提交请求的URI，*表示全部允许，在SpringMVC中，如果设成*，会自动转成当前请求头中的Origin
            corsConfiguration.addAllowedOrigin("*");
            // 允许访问的头信息,*表示全部
            corsConfiguration.addAllowedHeader("*");
            // 允许提交请求的方法类型，*表示全部允许
            corsConfiguration.addAllowedMethod("*");
            return corsConfiguration;
        }

        /**
         * 自定义跨域过滤器
         * @return
         */
        @Bean
        public CorsWebFilter corsFilter() {
            UrlBasedCorsConfigurationSource source = new UrlBasedCorsConfigurationSource(new PathPatternParser());
            source.registerCorsConfiguration("/**", buildConfig());
            return new CorsWebFilter(source);
        }

}
